Skip to content

Add project rename support in the sidebar#1798

Merged
juliusmarminge merged 1 commit intomainfrom
t3code/project-rename-ux
Apr 6, 2026
Merged

Add project rename support in the sidebar#1798
juliusmarminge merged 1 commit intomainfrom
t3code/project-rename-ux

Conversation

@juliusmarminge
Copy link
Copy Markdown
Member

@juliusmarminge juliusmarminge commented Apr 6, 2026

Closes #1370

CleanShot 2026-04-06 at 16 03 39@2x CleanShot 2026-04-06 at 16 03 42@2x

Summary

  • Adds inline project rename support from the sidebar project row context menu.
  • Commits project title changes through project.meta.update and clears rename state on blur, Enter, or Escape.
  • Updates orchestration store coverage so project.meta-updated refreshes the existing project name and timestamp.

Testing

  • bun fmt
  • bun lint
  • bun typecheck
  • bun run test

Note

Low Risk
Low risk UI/state changes that add a new project.meta.update command dispatch path; main risk is minor rename-state edge cases (blur/escape/enter) affecting sidebar interactions.

Overview
Adds inline project rename in the sidebar: a new "Rename project" context-menu action swaps the project title for an input, then commits on Enter/blur (or cancels on Escape) by dispatching project.meta.update.

Refactors thread renaming to pass explicit callbacks (onRenamingInputMount, hasRenameCommitted, markRenameCommitted) instead of exposing mutable refs, and ensures starting a rename clears any active rename state for the other entity (project vs thread).

Extends store tests to cover project.meta-updated updating an existing project’s name and updatedAt.

Reviewed by Cursor Bugbot for commit fe56ef0. Bugbot is set up for automated code reviews on this repo. Configure here.

Note

Add inline project rename support in the sidebar

  • Adds a 'Rename project' option to the project context menu in Sidebar.tsx, replacing the static project name with an inline input when active.
  • On Enter or blur, dispatches a project.meta.update command via the native API; on Escape, cancels without saving. Shows a toast on error.
  • Starting a project rename cancels any active thread rename, and vice versa.
  • Refactors thread rename props in SidebarThreadRow from ref-based to function-based (onRenamingInputMount, hasRenameCommitted, markRenameCommitted).
  • Adds a test in store.test.ts verifying that project.meta-updated events correctly update project title and updatedAt in state.

Macroscope summarized fe56ef0.

- Inline-edit project names from the sidebar context menu
- Handle project.meta-updated events in store state
@github-actions github-actions bot added size:L 100-499 changed lines (additions + deletions). vouch:trusted PR author is trusted by repo permissions or the VOUCHED list. labels Apr 6, 2026
@juliusmarminge juliusmarminge merged commit a221542 into main Apr 6, 2026
11 checks passed
@juliusmarminge juliusmarminge deleted the t3code/project-rename-ux branch April 6, 2026 23:06
@macroscopeapp
Copy link
Copy Markdown
Contributor

macroscopeapp bot commented Apr 6, 2026

Approvability

Verdict: Needs human review

This PR adds a new user-facing feature (project rename in sidebar) with new API integration to dispatch 'project.meta.update' commands. While the implementation follows existing patterns for thread renaming and is well-contained, new features introducing user-facing behavior warrant human review to verify the intended UX and API contract.

You can customize Macroscope's approvability policy. Learn more.

Aditya190803 pushed a commit to Aditya190803/t3code that referenced this pull request Apr 7, 2026
Chrono-byte pushed a commit to Chrono-byte/t3code that referenced this pull request Apr 7, 2026
gigq pushed a commit to gigq/t3code that referenced this pull request Apr 8, 2026
@MatthewFeroz
Copy link
Copy Markdown

Thank you for this, having an option to open file location would be nice as well. I will create a PR for this

rororowyourboat added a commit to rororowyourboat/t3code that referenced this pull request Apr 9, 2026
…threadId (#2)

* Raise slow RPC ack warning threshold to 15s (pingdotgg#1760)

* Use active worktree path for workspace saves (pingdotgg#1762)

* Stream git status updates over WebSocket (pingdotgg#1763)

Co-authored-by: codex <codex@users.noreply.github.com>

* fix(web): unwrap windows shell command wrappers (pingdotgg#1719)

* Rename "Chat" to "Build" in interaction mode toggle (pingdotgg#1769)

Co-authored-by: Julius Marminge <julius0216@outlook.com>

* Assign default capabilities to Codex custom models (pingdotgg#1793)

* Add project rename support in the sidebar (pingdotgg#1798)

* Support multi-select pending user inputs (pingdotgg#1797)

* Add Zed support to Open actions via editor command aliases (pingdotgg#1303)

Co-authored-by: codex <codex@users.noreply.github.com>
Co-authored-by: Julius Marminge <julius0216@outlook.com>

* Closes pingdotgg#1795 - Support building and developing in a devcontainer (pingdotgg#1791)

* Add explicit timeouts to CI and release workflows (pingdotgg#1825)

* fix(web): distinguish singular/plural in pending action submit label (pingdotgg#1826)

* Refactor web stores into atomic slices ready to split ChatView (pingdotgg#1708)

* Add VSCode Insiders and VSCodium icons (pingdotgg#1847)

* Prepare datamodel for multi-environment (pingdotgg#1765)

Co-authored-by: justsomelegs <145564979+justsomelegs@users.noreply.github.com>
Co-authored-by: codex <codex@users.noreply.github.com>
Co-authored-by: Cursor Agent <cursoragent@cursor.com>
Co-authored-by: cursor[bot] <206951365+cursor[bot]@users.noreply.github.com>

* Implement server auth bootstrap and pairing flow (pingdotgg#1768)

Co-authored-by: codex <codex@users.noreply.github.com>
Co-authored-by: Julius Marminge <julius@macmini.local>
Co-authored-by: Cursor Agent <cursoragent@cursor.com>
Co-authored-by: cursor[bot] <206951365+cursor[bot]@users.noreply.github.com>

* Use dev proxy for loopback auth and environment requests (pingdotgg#1853)

* Refresh local git status on turn completion (pingdotgg#1821)

Co-authored-by: codex <codex@users.noreply.github.com>

* fix(desktop): add Copy Link action for chat links (pingdotgg#1835)

* fix: map runtime modes to correct permission levels (pingdotgg#1587)

Co-authored-by: Julius Marminge <julius0216@outlook.com>
Co-authored-by: codex <codex@users.noreply.github.com>

* Fix persisted composer image hydration typo (pingdotgg#1831)

* Clarify environment and workspace picker labels (pingdotgg#1854)

* Scope git toast state by thread ref (pingdotgg#1855)

* fix build (pingdotgg#1859)

* Stabilize keybindings toast stream setup (pingdotgg#1860)

Co-authored-by: Julius Marminge <julius@macmini.local>

* feat(web): add embeddable thread route for canvas tile hosts

Adds /embed/thread/:environmentId/:threadId — a standalone route that
renders the existing ChatView without the app sidebar chrome. This is the
iframe target for t3-canvas agent shapes (see rororowyourboat/t3-canvas#3).

- New file-based route embed.thread.\$environmentId.\$threadId.tsx
- __root.tsx bypasses AppSidebarLayout for any /embed/* pathname so the
  environment connection + websocket surface + toasts still initialize
  but the sidebar/diff/plan chrome does not render
- minimal=1 search param is parsed and wired to a data attribute on the
  container for future targeted CSS; chrome hiding (BranchToolbar,
  PlanSidebar, ThreadTerminalDrawer) stays as a follow-up pass
- routeTree.gen.ts regenerated by the @tanstack/router-plugin

---------

Co-authored-by: Julius Marminge <julius0216@outlook.com>
Co-authored-by: codex <codex@users.noreply.github.com>
Co-authored-by: legs <145564979+justsomelegs@users.noreply.github.com>
Co-authored-by: sonder <168988030+heysonder@users.noreply.github.com>
Co-authored-by: Adem Ben Abdallah <96244394+AdemBenAbdallah@users.noreply.github.com>
Co-authored-by: Kyle Gottfried <6462596+Spitfire1900@users.noreply.github.com>
Co-authored-by: Jacob <589761+jvzijp@users.noreply.github.com>
Co-authored-by: Cursor Agent <cursoragent@cursor.com>
Co-authored-by: cursor[bot] <206951365+cursor[bot]@users.noreply.github.com>
Co-authored-by: Julius Marminge <julius@macmini.local>
Co-authored-by: Klemencina <56873773+Klemencina@users.noreply.github.com>
Co-authored-by: Oskar Sekutowicz <me.oski646@gmail.com>
Co-authored-by: Noxire <59626436+noxire-dev@users.noreply.github.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

size:L 100-499 changed lines (additions + deletions). vouch:trusted PR author is trusted by repo permissions or the VOUCHED list.

Projects

None yet

Development

Successfully merging this pull request may close these issues.

[Feature]: Rename Project

2 participants